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(57) Abstract 

A scalable control data networking system which has an 
open ended architectme and which is platfom and protocol 
independent. The servu' of this system accesses control data 
via a web browser over a network which receives data from a 
control network or direct I/O sources, translates die data to and 
from a generic control protocol, and manages communication 
of the generic control protocol with multiple cliuits. The 
server acts as a physical and network interface to the control 
network or direct I/O sources and translates Che native control 
data or direct I/O data (o and from a genericcontrol protocol 
format. The server also performs the function of managing 
communication with a plurality of clients using <^ten standards 
such as the TCP/IP protocol. Oat or more embedded applets 
graphically display the control data and permit the user to 
miHiitcn' and regulate the control data. 
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SERVER SYSTEM ANB METHOD FOR NETWORKING CONTROL 
NETWORKS AND DIRECT BNPUT/OUTPUT DEVICES 
WITH THE WORLD WIDE WEB 

5 

BACKGROUND OF THE INVENTION 

This invention pertains generatly to data communications, data processing and 
information retrieval in networked computer systems. More specifically, the present 
invention is a server system for accessing control data via web browsers over a network 

10 which receives data from a control network or direct I/O sources, translates the data to 
and from a generic control protocol, and manages communication of the generic control 
protocol with multiple clients. 

Vertically integrated, proprietary control data networking systems such as 
SCADA (Supervisory Control and Data Acquisition) systems are widely used in industry 

IS for numerous operations or procedures, including building so:urity, temperature control, 
and control of pressure or fluid levels in reactors and reservoirs. Figure 4 is a functional 
block diagram of a conventional vertically integrated control data networking system 
400. This system 400 comprises a plurality of client work stations 14a, 1 4b, 14c 
associated with a control network 1 8 by a netwoik connection 420. The control network 

20 has a plurality of devices shown generally as camera 20, air conditioner 22, motion 

sensor 24, temperature sensor 26 and door lock 28. A variety of device types may be 
associated with the control network 18. The workstations 14a, I4b, 14c communicate 
with the control network 1 8 through an application 440 on the workstations which Is 
specifically writtra for interfacing with the control network IS. Th^ vertically 

25 integrated contarol data networking systems are generally based on proprietary 

technologies and are not designed with open-ended architecttu^, and often are site- 
specific and device-specific. Thus, the systems lack scalability, are highly platform 
dependent, and are limited to specialized network architectures and protocols. As a 
result, these systems are not adaptable to rapidly changing computer networking 

30 technologies, and the selection of software and hardware which can be used with the 
systems is severely limited. 

Control networks such as LONWORKS™ and DEVICENET™ have more 
recently been employed in control data networking systons. These control networks are 
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somewhat more flexible than vertically integrated proprietary control data networking 
systMns because LONWORKS™ and DEViCENET™ have established standards thai 
reduce protocol conflicts and pennit limited open-ended architecture. However, in oider 
to implement these control networks a substantial investment in networking 

5 infrastructure, such as transmission media, routers and gateways is required. Further, 

existing control networks still lack scalability, are generally platform dependent, and are 
not readily adaptable to different protocols. TTius, it is currently difficult to.link control 
network subsystems into larger networics, connect control systems into wide area 
networics, implement supervisory control from one network to another, or provide 

10 generally for information flow between lower-level systems and higher level information 
networks. 

In both information and control networks generally, it is more cost-effective to 
levo^ge existing standards and technologies. Accordingly, there is a need for a scaleable 
control data networking system which has open ended architecture and which is platform 
15 and protocol independent. The present invention satisfies these needs, as well as others, 
and generally overcomes the deficiencies found in existing control data networking 
systems. 

SUMMARY OF THE INVENTIION 

20 The present invention is a server system and method for networiting control 

networks and direct input and output from devices to allow accessing of control data via 
the World Wide Web. In its most general terms, the system of the invention comprises a 
server and a plurality of »nbedded client applets. The server includes programming 
which carries out the operations of receiving control data from one or more direct I/O 

25 sources and/or control networks, translating the received control data into a generic 

control protocol, and managing cormnimication of the generic control protocol between 
the server and a plurality of clients. The plurality of client applets, which are embedded 
in a corresponding plurality of Web pages, communicate control data to the server using 
the gen^c control protocol, and present control data to client users in the form of 

30 graphical displays on the Web pages. 

The -World Wide Web" or "W^" is a client-server hypertext information and 
communication system popularly used on the intemet and intranet computer networks. 
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The ■Internet" is a cooperatively nm, globally distributed collection of computer 
networks which exchange infonnation through die Transmission Control 
Protocol/Internet Protocol (TCP/IP) protocol suite. "Hypertext" is text which is not 
constrained to a single linear sequence. The Web and Internet have made possible the 

5 sharing of information between computers all over the world through use of Web 
"browser" programs such as NETSCAPE NAVIGATOR™ and MICROSOFT 
EXPLORER™, which allow users to access the Web. An important feature of hypertext 
documents is diat they can contain special embedded "links" that enable users to connect 
with other related hypertext documents. Hypertext Transfer Protocol (HTTP) is the 

10 native protocol of the Web, and is used to transfer hypertext documents between 

computers networked through the Internet and Web. Hypertext documents are generally 
in the form of Hypertext Media Language (HTML) pages or Web pages. 

The development of the World Wide Web has been facilitated by the 
development of object oriented programming (OOP) languages for computers. OOP is a 

15 relatively new programming paradigm which allows computer programs to be broken 

down into component parts. Commonly used OOP languages include C++, JAVA and 
Smalltalk. OOP provides an implementation method wherein computer programs are 
organized as cooperative collections of software objects, each of which represents an 
instance of some class, with the classes being members or a hierarchy of classes united 

20 by inheritance relationships. Software objects generally comprise data fields in the form 
of instance variables that are encapsulated by one or more methods. Interconnected 
objects within a program communicate via messages. The enc^sulated nature of OOP 
allows OOP applications existing on a Web server to be downloaded to Web clients 
having varying types of machines and operating systems. The OOP JAVA is designed to 

25 be machine independent and function within different operating systems. JAVA permits 
scaled-down sq)plicalions called "applets" which can be incorporated into Web sites and 
nm off of individual HTML pages. JAVA applets require a JAVA-enabled browser 
such as the widely used NETSCAPE NAVIGATOR™ and MICROSOFT 
explorer™ browsers. 

30 Intonet working systems are typically built around a set of discrete systems 

which may be highly integrated, yet operate as fimctionally separate parts. The 
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encapsulated nature of OOP lends itself well to network and communication systems in 
that data from one protocol can be enc^sulated within methods of another protocol The 
encapsulating protocols must be open ended to allow data to be translated between 
different protocols. 

5 Many low level devices such as air conditioners, motion sensors, temperature 

sensors, cameras, and door locks have recently evolved to incorporate intelligence 
through increasingly inexpensive microprocessors which are embedded into the devices. 
This trend has created the potential for remotely accessing information associated with 
these devices, such as temperature, real time images, and device status. The present 

10 invention utilizes the World Wide Web and advantages of OOP to access such data via 
direct I/O of remote devices or from conUol networks associated with an array of 
devices, and to provide the data to Web clients independent of particular platfomis, 
protocols or network architectures. 

By way of example, and not of limitation, the server of the invention is embodied 

IS in a conventional programmed data processor such as a PC containing encoded 

executable instructions for carrying out program operations in accordance with the 
invention. The server includes a plurality of interfaces, with an infomiation network 
interface such as an ETHERNET TCP/IP interface, a control network interface which 
may be based on LONWORKS ™or DEVICENET™ standards, and a direct I/O 

20 interne. The web client programs are embodied in machines or woricstations such as 
PC, APPLE MACINTOSH™, UNIX™, or like programmed data processors which can 
support client or web browser programs such as NETSCAPE NAVIGATOR™ and 
MICROSOFT EXPLORER™ as well as a plurality of HTML pages. 

By way of example, and not of limitation, a single static JAVA client object is 

25 included per each of the plurality of HTML page. One or more sq)arate input and output 
JAVA applets on the HTML page provide gr^hical user interface (GUI) applet devices 
or widgets which access the static JAVA client object for accessing control data. The 
server is netwoiked to the static JAVA client applets via conventional TCP/IP sockets. 
Otha- alternative networking means may be used as alternatives to TCP/IP sockets, 

30 including distributed object method invocations, such as CORBA calls managed by an 

external Object Request Broker or OLE. Since the GUI applets are JAVA based and run 
off the HTML pages rather than being server-pushed, the applets provide for real time 
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client user interaction. 

The programming associated with the server includes conventional software 
applications for providing information and/or services to client programs according to 
client program requests. The server of the invention also comprises programming means 
5 for carrying out the operations of: 

(a) managing communications with a plurality of clients; 

(b) performing control data translations or exchanges between a generic 
control protocol and native control data formats; and 

(c) interfacing to control networks and/or direct I/O. 

10 ^ (d) intelligent management of control data including data aggregation, event 

monitoring, and data logging. 

In performing control data translations between the generic control protocol and 
native control data formats, the programming preferably also provides means for carrying 
out the operations of identifying I/O points, identifying data points, and data formatting. 

15 The translating operates in both directions, and the server architecture and programming 
handles control data requests and assignments from the GUI applets and control data 
updates and results from the control network and/or direct I/O points. 

The server system of the invention prefoably incorporates both polling and event 
driven methods of control data exchange. The generic control protocol of the invention 

20 preferably comprises: 

(a) means for providing node identification; 

(b) means for providing I/O point identification; 

(c) means for providing data types; 

(d) means for providing data units; and 
25 (e) means for providing data values. 

In using the invention, a user at a client workstation runs the web browser 
program and establishes a network connection with the server via modem and diat-up 
s^al connection or other standard manner. The user identifies the location or address 
for the desired HTML page(s) corresponding to the particular control data which the user 
30 wants to access by URL (Uniform Resource Locator) address or other standard means. 

The embedded applets on the selected HTML page(s) graphically display the control data 
from the remote devices and provide selectable options to the user, such as setting or 
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parameter changes for the remote devices. The user can select particular desired control 
data by "clicking'* on the appropriate applet using a mouse» tracking ball or other 
conventional means. After viewing the selected control data, the user can change a 
setting or control on the remote device by clicking on the appropriate applet. 

An object of the invention is to provide a server system and method for 
networking control networks and direct input and output which allows remote accessing 
of control data via the World Wide Web. 

Anoth^ object of the invention is to provide a server system and method for 
neiworicing control networks and direct input and output which has an open-ended 
architecture and is scalable. 

Another object of the invention is to provide a server system and method for 
networking control networks and direct input and output which is platform and protocol 
independent. 

Another object of the invention is to provide a server system and method for 
networking control networks and direct input and output which utilizes embedded applets 
networked to a server for communicating control data. 

Another object of ttie invention is to provide a server system and method for 
networking control networks and direct input and output which translates native control 
data formats to a generic control protocol which accommodates data and I/O point 
identification schemes of multiple different control networic protocols without losing 
information from any protocols. 

Another object of the invention is to provide a server system and method for 
networking control networks and direct input and output which manages communication 
of control data with multiple clients. 

Another object of the invention is to provide a server system and method for 
networking control networks and direct input and output which allows the linking of 
control network subsystons into large netwoiks. 

Ano&or object of the invoition is to provide a server system and method for 
networking control networks and direct ir^ut and ou^ut which allows information flow 
from low level systems to higho- level systrans. 

Further objects and advantages of the invention will be brought out in the 
following portions of the specification, wherein the d^led description is for the purpose 
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of fully disclosing preferred embodiments of the invention without placing limitations 
thereon. 

BRIEF DESCMFTION OF TEE KWRA WINGS 
5 The invention will be more fiilly understood by reference to the following 

drawings, which are for illustrative purposes. * 

FIG. 1 is a functional block diagram of a server syst«n for networking control 
netwoiks and direct input and output in accordance with the present invention which 
illustrates generally the architectural components of the invention, 
to FIG. 2 is a functional block diagram of a server system for networking control 

networks and direct input and output in accordance with the present invention which 
illustrates the logical operation of the invention. 

FIG. 3 is a functional block diagram of a server system for networking control 
networks and direct input and output in accordance with the present invention which 
15 illustrates a specific preferred implementation architecture for the invention. 

FIG. 4 is a functional block diagram of a conventional vertically integrated 
networking system, 

FIG. 5 is a flow chart digram of the translation of messages from the GCP to 
control data format in accordance with the present invention. 
20 FIG. 6 is a flow chart diagram of the translation of messages from the control 

data format to the general control protocol in accordance with the present invention. 

DETAILED DESCSaiPTIION OF THE PStEFERRED EMBODIMENTS 

Referring more specifically to the drawings, for illustrative purposes the present 

25 inv^tion is embodied in the server system generally shown in FIG. 1 through FIG. 3. U 

will be appreciated that the server ^tem may vary as to configuration and as to details 
of the components and architecture, and that the method may vary as to details and the 
order of the Steps without dq)arting from the basic concepts as disclosed herein. 

Referring now to FIG. 1, a server system 10 in accordance with the invention is 

30 generally shown. System 10 includes a s^er 12 and a plurality of client work stations 
1 4a, 14b. 1 4c associated with server 12 by a corresponding plurality of wide area 
n^ork connections 16a, 16b, 16c. Server 12 is also networked with a control network 
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18 having a plurality of devices shown generally as camera 20, air conditioner 22, 
motion sensor 24. temperature sensor 26 and door lock 28. The particular nature of 
devices 20-28 is exemplary, and a variety of device types which perform monitoring 
and/or control functions may be associated with control network 18. Network 

5 connection 30 links server 1 2 with control network 1 8. Network connection 30 could 
alternatively link with an array of direct I/O from separate devices instead of, or in 
addition to control network 18. 

Server 12 is preferably a conventional programmed data processor or computer 
having logic circuits implemented in hardware and/or software which perform various 

10 operations, described more fully below, according to computer programming based on 

exNutable instructions encoded in a computer memory of server 12. Workstations 14a- 
c likewise are preferably conventional progranuned data processors having logic circuits 
implonented in hardware and/or software which support starulard client applications 
operating with standard comm^ial platforms or operating systems such as 

15 WINDOWS™ MACINTOSH™, UNIX™, orthe like. Control networic 18 is a local area 
network (LAN) based on LONWORKS™. DEVICENET™ or like control network 
standards. 

The devices 20-28 associated with control network 18 are "smart" and include a 
microprocessor or computer (not shown) embedded in or otherwise associated with each 

20 device 20-28. The embedded microprocessors include conventional means for 

monitoring and communicating status and otbo- control data of devices 20-28 to control 
network IS. Devices 20-28 are linked within control network 18 by standard means. 
Network cormections 16a-c and 30 are standard connections which, at the physical layer, 
preferably comprise modems and dial-up serial connections. 

25 Client workst^ons I4a-c each support a browser program 32 such as 

NETSCAPE NAVIGATOR™. MICROSOFT EXPLORER™ or like client application. 
Each woric station 14a-c may sq)poTt multiple browsers 32, although only one is shown 
for reasons of clarity. Each browser 32 supports a plurality of HTML pages 34, of which 
only one is shown for clarity. Each HTML page 34 in turn supports a plurality of 

30 embedded applets 36a-c. As noted above, applets 36a-c are preferably JAVA GUI 

applets which graphically provide aser interfaces for displaying data and allowing client 
users to change settings or parameters of devices 20-28 from remote locations via the 
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Web. 

Embedded applets 36a-c and HTML page 34 are platform independent, and any 
browser 32 (which can support applets) as well as any type of client workstation 14a-c 
may be used with system 10. Likewise, the nature and configuration of control network 

5 1 8 may be varied depending upon particular situations wherein system 1 0 is employed. 

Thus, multiple applets 36a-c on each HTML page 32, muhiple HTML pages 34 on each 
web browser 32, multiple web browsers 32 on each workstation 14a-c, and multiple 
workstations 1 4a-c all communicate with a single server 1 2 over a network. Server 12 
manages the client ^plets 36a-c on one side of system 10, and communicates with 

10 control network 18 on the other side of system 10. 

The server 12 in accordance with the present invention translates the data from 
the workstations 14a-c from the platform independent form to a platform dependent form 
which the control network 18 can understand. Likewise, the server 12 translates the data 
from the control network 18 from a platform dependent form to a platform independent 

IS fonn which is imderstood by the woricstations 14a-c. 

The logical operation of the invention will be more fully understood by referwice 
to FIG. 2 as well as FIG. 1. wherein the logical architecture 33 of the system 10 of the 
invention is shown. Generally, multiple ^lets 36a-c run on each HTML page 34a-c, as 
described above. HTML version 3.2 supports applet tags which allow applets 36a-c to 

20 run when HTML pages 34a-c are loaded to a web browser(s). The applet tags also allow 
applets 36a-c to draw to a particular desired section of the screen area of HTML page 
34aTC. 

Each applet 36a-c generally performs two functions: the display of c:onlroI data in 
graphical form to users, and commtmication of control d^ with server. The display of 

25 control data to users, shown as Control Data Display program operation 38, is preferably 
provided in the form of a graphical user interface or GUI devices (not shown). The GUI 
devices may be in the form of a gauge, graph, button, dial, meter, slider, text or like 
conventional GUI devices. Means for transfonning control data into various desired 
formats or units are included with applets 36a-c, and prefmibly comprise suitable input 

30 and output GUI devices such as buttons, text, sliders, dials, lights, gauges, graphs (bar 

and/or plot) or like icons which suitably positioned on HTML pages 34a< and which can 
be selected and actuated by a user via "clicking" on the GUI device with a mouse. 
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tracking ball or like user interface device. 

Each applet 36a-c also includes means for communicating control data with 
server 1 2 using a Generic Control Protocol (GCP). The GCP. which is described fiirther 
below, is non-specific as to forms of control networking or I/O types. The means for 
sending and receiving or otherwise communicating control data widi server 12 in GCP is 
shown generally as Send/Receive Control Dato in GCP program operation 40. 

Server 12 is connected to applets 36a-c at the physical level by network 
coimections 16a-c. and to control network 18 or other source of control data by network 
connection 30. Server 1 2 includes programming means for carrying out the operations 
of: 

(a) managing communications with a plurality of clients; 

(b) performing translations between a Generic Control Protocol and native 
control data formats of devices 20-28 and/or control network 1 8; and 

(c) interfacing to control networks 1 8 and/or direct I/Os of non-networked 
devices. 

(d) intelligent management of control data including data aggregation, event 
monitoring^ and data logging. 

The communication managing means of server 12, shown as communication 
management program operation 42, allows communication between server 12 and 
multiple client workstations 14a-c. and thus multiple £q)plets 36a-c» which may be on the 
same or difterent HTML pages 34a-c, browsers 32 or workstations 14a-c, can 
communicate with server 12 simultaneously. 

The translation p»forming means of server 12, shown as GCP/control data 
translation program operation 44, performs control data translations between the Generic 
Control Protocol and native control data formats. The translation perfoiming means also 
preferably comprises programming means for carrying out the operations of identifying 
1/0 points, identifying data points, and data formatting. The translation performing 
means operates in both directions (GCP to native control data format and native control 
data format to GCP), and handles control data requests and assignments from the GUT 
applets and control data updates and results from the control network and/or direct I/O 
points. 

The translation performing means are illustrated in Figures 5 and 6. Figure S is a 
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flow chart diagram of the translation of messages from the GCP to control data format in 
accordance with the present invention. The server 12 begins at an idle status, via step 
502. When a message arrives from a woricstation 14a-14c, via step 504. it is first parsed 
out into data units which correspond to data units on the control network, via step 506. 

5 Then the data units are each translated from the GCP to the control protocol foimat, via 
step 508. The translated data units are then transmitted to the control network, setting the 
corresponding control network data units to the appropriate values, via step 5 1 0. From 
these values, control network messages are initiated, via step 5 12. The messages 
prompts the actions which are appropriate for the values of the data units. 

10 Figure 6 is a flow chart diagram of the translation of messages from the control 

data format to the GCP in accordance with the present invention. Again, the server 1 2 
begins at an idle status, via step 602. When the time comes to send updates for the 
values of the data units on the control network, via step 604, the server 12 fetches the 
control network data unit values to be i^dated. via step 606. Conditions prompting a 

IS sending of updates include a request for t^ates from a client, updates which are 
periodically sent and updates sent based on a condition, such as the changing of a 
temperature past a threshold. It packs the data units into a single message via step 608, 
encodes the message from the control protocol format to the GCP via step 61 0, and then 
transmits the message to the proper workstations I4a-I4c, via step 612. 

20 The interfacing means of server 12, shown generally as control data interface 

program opoation 46, provides a logical interface with control network 1 8 or other 
control data sources such as an array of direct I/O points. 

The server architecture 33 comprises primarily server 12 and its program 
operations, and embedded applets 36a-c and tiieir program operations. The hardware 

25 supporting architecture 33 is prefoably as generic and interchangeable as possible lo 

allow open-endedness, scalability and adaptability to changing technologies. The 
architecture 33 permits sufficient flexibility so that at least one applet 36a-c, on at least 
one HTML page 34a-c, on at least one browser 32, on at least one work station 14a-c can 
be utilized. 

30 Referring now to FIG. 3. as well as FIG. I and FIG. 2, a preferred 

implem^tation of the invention is generally shown as architecture 48, wherein like 
reference numbers denote like conq»onents. Preferably, a single st^c JAVA Client 
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Object 50 is used per HTML page 34a-c. Applets 36a-c are preferably JAVA GUI 
^plets, each of which makes calls to JAVA Client Object 50 by messages 52a-c, Each 
JAVA GUI applet 36a-c has an associated GUI device 54. of which only one is shown 
for clarity. 

Generally, the servra- system of the invention will incorporate both polling and 
event-driven methods of control data exchange. In the preferred architecture 48. one 
JAVA Client Object 50 exists per HTML page 34a-c. JAVA Ghent Objects 50 are static, 
and each include an initQ initialization method called by each JAVA GUI applet 36a-^ 
which creates JAVA Client Object 50 if it not already present. Each JAVA Client Object 
50 also includes updateQ methods that register JAVA GUI ^lets 36a-c for proper 
updates, which arc preferably polling or event-driven, as related above. 

JAVA Client Object 50 manages control data updates with server 12 and 
manages communications with each of the multiple JAVA GUI applets 36a-c. Each 
JAVA Client Object 50 sends and receives control data in Generic Control Protocol, 
shown as Send/Receive Control Data in GCP operation 40. Each JAVA Client Object 50 
registers as a client of server 12, accepts registration from multiple JAVA GUI applets 
36a-c, and establishes a set of polling or event-driven updates to be routed between 
JAVA GUI applets 36a-c and server 12. JAVA Client Objects 50 preferably 
communicate with server 12 via a plurality of TCP/IP sockets 56a-c over corresponding 
physical layer connections 16a-c (FIG. 1). TCP/IP sockets 56a-c may be modified to 
utilize distributed object invocation methods such as CORBA (Common Object Request 
Broker Architecture) calls managed by an cxtemal object broker. CORBA provides an 
open object infrastructure wherein object interfaces are described in IDL (Interface 
Definition Language). Alternatively, TCP/IP sockets may be modified to utilize OLE 
(Object Linking and Embedding) standards for distributed objects. However, OLE is 
currently supported only by MICROSOFT™, and does not provide connectivity between 
different platforms as does CORBA. Other distributed object standards, such as DCE 
(Distributed Computing Environment), may alternatively be used in association with 
TCP/IP sockets, depending upon particular uses of the invention. 

JAVA GUI applets 36a-c support methods to display changing control data from 
devices 20-28 in control network 18 according to client user specifications. JAVA GUI 
applets 36a-c display control data on HTML pages 34a-c via GUI devices 54. GUI 
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devices 54 are preferably familiar or common graphical items such as gauges, graphs, 
buttons, dials, meters, sliders, text or like conventional icons. GUI devices 54 include 
both input GUI devices and output GUI devices. Parameters that JAVA GUI applets 36 
accept as arguments whea called from an HTML page 34a-c preferably include: 

(a) size of GUI devices 54; 

(b) screen position of GUI devices 54; 

(c) polling frequency or event threshold value; 

(d) control data identifier (control network node or direct I/O point); 

(e) specific GUI parameters (labels, colors, options and the like). 

When called from an HTML page 34a-c, each JAVA GUI applet 36a-c registers with the 
JAVA Client Object 50 for that particular HTML page and passes the relevant 
parameters to the JAVA Client Object 50. These parametera preferably include polling 
frequencies, event threshold values, and control data identifiers. As the JAVA Client 
Object 50 updates, JAVA GUI applets show changes in control data via GUI devices 54 
on the HTML page 34a-c. 

Server 12 preferably comprises an embedded PC with an interface to infomiation 
network and an interface to control network 18 and/or direct device I/Os. As noted 
above, network connections 16a-c are prefraably ETHERNET using the TCP/IP protocol 
suite. Server 12 includes programming means for managing communications with a 
plurality of JAVA Client Objects 50, which is shown generally as communication 
management operation 42. Server 12 manages JAVA client objects 50. and preferably 
handles multiple JAVA Qient Objects 50 via multiple open TCP/IP sockets 56a-c. 
Registration and data requests are handled by the JAVA Client Objects 50, and events 
and data from control network 1 8 are propagated to all registered JAVA Client Objects 
50. 

Server 12 also includes programming means for performing translations of 
control data and control data requests brtween a Generic Control Protocol and the native 
control data formats of devices 20-28 and/or control network 1 8. shown generally as 
GCP control data translation operation 44. This operation includes I/O point 
identification, data types, and data formatting. The translating operates in both 
dhwtions, handling control data requests and assignments &om JAVA GUI applets 36a- 
c, as well as control data updates and results from control network 18 and/or direct I/O 
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points. 

Server 12 also includes programming means for interfacing with control network 
18 and/or direct I/Os of non-networked devices. In the case of the preferred architecture 
48 shown in FIG. 3 wherein control network 1 8 is a LONWORKS™ control network. 

The Generic Control Protocol of the invention can accommodate data and 1/0 
point identification schemes of various different control network protocols without losing 
any information ftom any particular protocol. The Generic Control Protocol preferably 
includes 

(a) means for providing node identification; 

(b) means for providing I/O point identification; 

(c) means for providing data types; 

(d) means for providing data units; and 

(e) means for providing data values. 
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What is claimed is: 

1 . A method for providing computer network connectivity, the computer 
network including a control network and a plurality of workstations coupled to the 
conttol network, the control network including a specific control protocol, and the 
plurality of woricstations including a generic control protocol, the method comprising: 

(a) communicating control data in the generic control protocol format 
between the plurality of workstations and the server, 

(b) translating control data fipom the generic control protocol format to 
the specific control protocol format and from the specific control protocol format to the 
generic control protocol format; and 

(c) communicating control data in the specific control protocol format 
between the server and the control network. 

2. The method of claim 1 , wherein the translating step (b) comprises: 

(bl) parsing out a plurality of data units in the generic control protocol 

format; 

(b2} translating each of the plurality of parsed out data units ii-om the 
generic control protocol format to the specific control protocol format; 

(b3) setting the VEdues of a plurality of control network data units 
which correspond to the plurality of parsed out translated data units; and 

0>4) means for initiating control network messages according to the 
values of the plurality of control netwoiic data units. 

3. The method of claim 1 , wherein the translating step (b) comprises: 
(bl) fetching the values of aplurality of control network data units in 

the specific control protocol format; 

Q>2) packing the plurality of control network data units into a single 

message; and 

(b3) encoding the single message into the generic control protocol 
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format. 

4. The method of claim 1 » wherein each of the plurality of workstations 
comprise: 

(a) at least one web browser program; 

(b) a plurality of Hypertext Media Language pages supported by the 
web browser programs; and 

(c) a plurality of embedded applets supported by the Hypertext Media 
Language pages. 

5. The method of claim 4, wherein the embedded applets function as the 
means for communicating control data in the generic control protocol format between the 
server and the plurality of workstations. 



15 6. The method of claim 1, wherein the translating step (b) further comprises: 

(bl) identifying input/output points; 
(b2} identifying data points; and 
(b3) identifying data formatting. 

20 7. The method of claim 1 , wherein the generic control protocol of the 

translating step (b) comprises: 

(a) providing node idoitification; 

(b) providing input/output point identification; 

(c) providing data types; 

25 (d) providing data units; and 

(e) providing data values. 

8. A system for computer networic connectivity, the computer network 
including a control network and a plurality of workstations coupled to the control 
30 network, the control network including a specific control protocol, and the plurality of 

workstations including a generic control protocol, the system comprising: 

means for communicating control data in the generic control protocol 
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fonnat between the server and the plurality of workstations; 

means for translating control data from the generic control protocol 
fonnat to the specific control protocol formal and from the specific control protocol 
fonnat to the generic control protocol format; and 
5 means for communicating control data in the specific control protocol 

format between the server and the control network. 

9. The system of claim 8, wherein the translating means comprises: 
means for parsing out a plurality of data units in the generic control 
10 protocol format; 

means for translating each of the plurality of parsed out data units from 
the generic control protocol format to the specific control protocol format; 

means for setting the values for a plurality of control network data imits 
which correspond to the plurality of parsed out translated data units; and 
IS means for initiating control network messages according to the values of 

the plurality of control network data units. 

to. The system of claim 8, wh^ein the translating means comprises: 

means for fetching the vahies of a plurality ^of control network data units 
20 in the specific control protocol format; 

means for packing the plursdity of control network data units into a single 

message; and 

means for encoding the single message into the generic control protocol 

format. 

25 

11. The system of claim 8, whoein each of the plurality of workstations 
comprise: 

(a) at least one web browser program; 

(b) a plurality of Hypertext Media Language pages supported by the 
30 web browser programs; and 

(c) a phirality of embedded applets supported by the Hypertext Media 
Language pages. 
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to 



12. The system of claim 11 , wherein the embedded applets function as the 
means for communicating control data in the generic control protocol format between the 
server and the plurality of workstations. 

1 3. The system of claim 8, wherein the translating means further comprises: 
means of identifying input/output points; 

means for identifying data points; and 
means for identifying data formatting. 



14. The system of claim 8, wherein the generic control protocol comprises: 
means for providing node identification; 

means for providing input/output point identification; 
means for providing data types; 
IS means for providing data units; and 

means for providing data values. 

15. A server for a computer network system, the computer networic system 
including a control network and a plurality of workstations, the control network 
including a specific control protocol and the plurality of workstations including a 

20 generic control protocol, the server comprising: 

(a) means for communicating control data in the generic control 
protocol format with the plurality of workstations; 

(b) means for translating control data in the generic control protocol 
format to the specific control protocol format and from the specific control protocol 

25 format to the generic control protocol format; and 

(c) means for communicating control data in the specific control 
protocol format with the control network. 

16. The method of claim 15, wherein the translating step (b) comprises: 

30 (b 1 ) parsing out a plurality of data imits in the generic control protocol 

format; 



(b2) translating each of the plurality of parsed out data units from the 
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generic control protocol format to the specific control protocol fonnat; 

(b3) setting the values of a plurality of control network data units 
which correspond to the plurality of parsed out translated data imits; and 

(b4) means for initiating control networic messages according to the 
values of the plurality of control network data units. 

1 7. The method of claim 15, wherein the translating step (b) comprises: 

(bl) fetching the values of a plurality of control network data units in 
the specific control protocol fonnat; 

(b2) packing the plurality of control network data units into a single 

message; and 

(b3) encoding the single message into the generic control protocol 

format. 

IS. The system of claim 13, wherein each of the plurality of workstations 
comprise: 

(a) at least one web browser program; 

(b) a plurality of Hypertext Media Language pages supported by the 
web browser programs; and 

(c) a plurality of embedded applets supported by the Hypertext Media 
Language pages. 

19. The system of claim 18, wherein the embedded ^plets function as the 
means for communicating control data in the generic control protocol format between the 
server and the plurality of workstations. 

20. The system of claim 15, wherein the translating means further comprises: 
means of identifying input/output points; 

means for identifying data points; and 
means for identifying data formatting. 

21 . The system of claim 15, wherein the generic control protocol comprises: 
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means for providing node identification; 

means for providing input/output point identification; 

means for providing data types; 

means for providing data units; and 

means for providing data values. 



22. A computer readable medium with computer instructions for providing 
computer network connectivity, the computer networic including a control network and a 
plurality of workstations, the instructions for 

a) communicating control data in the generic control protocol format 
between the plurality of workstations and the server; 

b) translating control data &om the generic control protocol format to 
the specific control protocol format and from the specific control protocol format to the 
generic control protocol format; and 

c) communicating control data in the specific control protocol format 
between the server and the control network. 



23. The computer readable medium of claim 22, wherein the instructions for 
the transl^ng means comprises: 

means for parsing out a plurality of data units in the generic control 
protocol format; 

means for translating each of the plurality of parsed out translated data 
units from the generic control protocol format to the specific control protocol format; 

means for setting the values of a plurality of control network data units 
which correspond to the plurality of parsed out data units; and 

means for initiating control network messages according to the values of 
the plurality of control network data units. 

24. The computer readable mediimi of claim 22, wherein the instructions for 
the translating means comprises: 

means for feting values of aplurality of control n^ork data units in 
the specific control protocol format; 
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means for packing the plurality of control network data units into a single 

message; and 

means for encoding the single message into the generic control protocol 

format. 
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